草庐IT

没有框架的javascript ajax请求

全部标签

ruby - 如果没有将 `begin ... end` 用作代码块,Ruby 的 `rescue` 是否会产生意想不到的后果?

我偶尔会看到begin...endblock在ruby​​中使用而没有任何rescue,else,ensure等之间的语句。例如:foo=beginwhatever=3"great"42end编码人员的意图似乎是使用begin...endblock只是为了它的block分组质量(就好像begin是do)。我个人认为这种用法有点违反最小意外原则(begin对我来说意味着异常处理)。以这种方式使用begin...end是否有任何意想不到的后果?begin...endblock是否有任何语义差异(可能在异常处理中?),使这种用法变得危险?Ruby的语法非常微妙,如果这里有奇怪的陷阱,我也不会

ruby-on-rails - 如何在 ruby​​ ActiveRecord 中销毁没有 ID 列的记录?

我有一个没有ID列的表。当我尝试使用ActiveRecord从中删除时,生成的SQL是DELETEFROMtable_nameWHEREID=NULL,这显然不起作用。有什么方法可以使用ActiveRecord从表中删除,或者至少运行带有占位符的原始SQL删除查询(因此它不易受到SQL注入(inject)的攻击)? 最佳答案 您是否尝试过使用ActiveRecord的delete_all方法?这是我的沙箱中的摘录:>>customer=Customer.new(:login=>'foo')=>#,discount:0,last_fo

ruby - 以编程方式确定是否安装了某个 gem,如果没有则安装它

这看起来并不难。我想要一个ruby​​脚本来判断某个gem(任何版本,和/或某个版本规范)当前是否安装在系统上(无论gemlist在哪里),如果没有,安装它。是的,我知道在某些情况下,bundler在这方面做得很好。相信我,我有一个案例,出于奇怪的原因我不想使用bundler。我真的很想以编程方式询问本地的gemrepo。当然,一种以编程方式安装的方法就是将shellout到geminstall。但我无法找到一种可靠的方法来以编程方式询问以查看是否安装了特定的gem,而不是使用shellout,不是使用ruby​​gemapi,什么都不是。我错过了吗? 最佳

ruby - 没有安装 jekyll-paginate 或其依赖项之一

我已经安装了这个jekylltheme.但面临一个问题。如果我这样做:bundleexecjekyllserve一切正常(_site文件夹包含必要的文件并且服务器正在运行),但是如果我使用以下命令:jekyllbuild-d/var/www/budka/data/www/blog我得到错误:DependencyError:Yikes!Itlookslikeyoudon'thavejekyll-paginateoroneofitsdependenciesinstalled.InordertouseJekyllascurrentlyconfigured,you'llneedtoinstal

ruby-on-rails - 将 api key 添加到 ActiveResource 中的每个请求

我有2个RESTfulRails应用程序,我试图让彼此交谈。两者都是用Rails3(目前是beta3)编写的。对服务的请求将需要使用一个apikey,它只是每个请求都需要的参数。我似乎找不到有关如何执行此操作的任何信息。您通过site=方法定义资源连接到的url。应该有等效的query_params=方法或类似方法。我发现了一篇与此相关的好博文,它是从2008年10月开始的,所以对Rails3不是很有用。更新:我有一个想法。一个小型的Rack中间件或Metal会是这个问题的答案吗?它可以直接通过请求,将它的api_key添加上。 最佳答案

ruby-on-rails - 如何在没有 RVM 的情况下在 Ubuntu 上安装 Ruby 1.9.3?

我想在没有rvm的Ubuntu上安装ruby​​1.9.3我跑sudoapt-getinstallruby它采用ruby​​1.8和ruby​​1.9.1。如果我这样做了sudoapt-getinstallruby1.9.3-pXXXX我仍然无法安装ruby​​。如何在Ubuntu上安装ruby​​? 最佳答案 在Ubuntu12.04LTS上,我让它与以下系统一起工作:sudoapt-getinstallruby1.9.3cd/etc/alternativessudoln-sf/usr/bin/ruby1.9.3ruby

ruby - 为什么要在框架 Web 服务器前面使用 http 服务器?

sinatra(ruby)、play(scala)、lift(scala)等Web应用程序框架会生成一个监听特定端口的Web服务器。我知道有一些原因,例如安全性、集群以及在某些情况下的性能,可能会导致我在我的Web应用程序之前使用ApacheWeb服务器。根据您的经验,您有什么原因吗? 最佳答案 任何网络应用程序的一部分都具有完全标准化和商品化的功能。nginx或apache等成熟的Web服务器可以执行以下操作。它们可以以更正确、更高效、更稳定、更安全、系统管理员更熟悉并且比您可以在应用程序服务器中重写的任何方式更容易配置的方式来执

没有 do end 的 Ruby 多行代码块

我是Ruby的初学者,所以很抱歉问这么简单的问题,但是这段代码有什么问题吗-3.upto(9){print"Hello"puts"World"}或3.upto(9){|n|print"Hello"putsn}它工作得很好,但我看到的大多数代码示例都使用了的语法3.upto(9)do|n|print"Hello"putsnend仅对单个语句使用花括号只是惯例吗?来自C/C#的第一个对我来说似乎更自然,但在罗马时! 最佳答案 这两种语法之间存在细微差别。{}的优先级高于do...end。因此,以下将传递bar和一个block到方法foo

ruby - 在没有 `autoload` 的情况下在 Ruby 中自动加载类

我爱theautoloadfunctionalityofRuby;然而,它是goingawayinfutureversionsofRuby因为它从来都不是线程安全的。所以现在我想假装它已经消失并在没有它的情况下编写我的代码,方法是自己实现延迟加载机制。我想以最简单的方式实现它(我现在不关心线程安全)。Ruby应该允许我们这样做。让我们从扩充一个类开始const_missing:classDummydefself.const_missing(const)puts"const_missing(#{const.inspect})"super(const)endend当我们尝试引用“Dummy

ruby-on-rails - Ruby:在没有 Rails 的情况下从 gem 访问 rake 任务

我知道Rake任务可以在Rubygem中的许多地方定义:在Rakefile中在tasks/*.rake中在lib/tasks/*.rake中我读到前两个应该在gem本身上执行任务时使用。当任务需要公开时,似乎应该选择第三个选项。有许多在线教程演示了使用Rails从gem加载Rake任务的各种方法,即利用Rails::RailTie。但是,我想找到一种在不需要Rails的情况下在另一个gem中使用依赖项gem的任务的方法。有没有简单的解决方法?是否有人愿意描述正确的方法,或概述哪些方法可行?更新我已经尝试创建一个文件bin/my-gem以便在系统上可以从my-gem执行Rake任务。我已